# Chapter 7: Microarchitecture

# Single-Cycle Control

# Single-Cycle Control



# Single-Cycle Control: Main Decoder

| ор | Instr. | RegWrite | ImmSrc | ALUSrc | MemWrite | ResultSrc | Branch | ALUOp |
|----|--------|----------|--------|--------|----------|-----------|--------|-------|
| 3  | lw     |          |        |        |          |           |        |       |
| 35 | sw     |          |        |        |          |           |        |       |
| 51 | R-type |          |        |        |          |           |        |       |
| 99 | beq    |          |        |        |          |           |        |       |



#### Review: ALU

| ALUControl <sub>2:0</sub> | Function |
|---------------------------|----------|
| 000                       | add      |
| 001                       | subtract |
| 010                       | and      |
| 011                       | or       |
| 101                       | SLT      |



#### Review: ALU

| ALUControl <sub>2:0</sub> | Function |
|---------------------------|----------|
| 000                       | add      |
| 001                       | subtract |
| 010                       | and      |
| 011                       | or       |
| 101                       | SLT      |



#### Single-Cycle Control: ALU Decoder



# Single-Cycle Control: ALU Decoder

| ALUOp | funct3            | op <sub>5</sub> , funct7 <sub>5</sub> | Instruction | ALUControl <sub>2:0</sub> |  |
|-------|-------------------|---------------------------------------|-------------|---------------------------|--|
| 00    | Х                 | Х                                     | lw, sw      | 000 (add)                 |  |
| 01    | Х                 | X                                     | beq         | 001 (subtract)            |  |
| 10    | 10 000 00, 01, 10 |                                       | add         | 000 (add)                 |  |
|       | 000               | 11                                    | sub         | 001 (subtract)            |  |
|       | 010               | Х                                     | slt         | 101 (set less than)       |  |
|       | 110               | Х                                     | or          | 011 (or)                  |  |
|       | 111               | X                                     | and         | 010 (and)                 |  |



# Example: and

| ор | Instruct | RegWrite | ImmSrc | ALUSrc | MemWrite | ResultSrc | Branch | ALUOp |
|----|----------|----------|--------|--------|----------|-----------|--------|-------|
| 51 | R-type   | 1        | XX     | 0      | 0        | 0         | 0      | 10    |

